## Lab 4 report

Name: Oscar Stark Student ID: F11015127

In this lab I used the 7 segment display of the FPGA board to display numbers. Only the code for the advanced task is shown on this report, because the advanced is just an extension of the basic task.

## Code

```
module seven(
    input [3:0] SW, // 4 switches to change the number being displayed
    input [2:0] SW2, // 3 switches to choose the 7-segment display (7SD)
    output [13:0] OVT, // the output for the 7SD (the array has size 14 because the first 4 7SD are controlled separatedly of the last 4 7SD)
    output [7:0] I // this is a one hot vector that lights up the choosen 7-segment display
    reg [13:0] OUT;
    reg [7:0] D;
    always@(SW) // this controls how the 7SD lights up
        case({SW})
             4'b0000: {OUT} = 14'b111111011111110; //0
             4'b0001: {OUT} = 14'b01100000110000; //1
             4'b0010: {OUT} = 14'b11011011101101; //2
             4'b0011: {OUT} = 14'b111100111111001; //3
             4'b0100: {OUT} = 14'b01100110110011; //4
             4'b0101: {OUT} = 14'b10110111011011; #5
             4'b0110: {OUT} = 14'b10111111011111; #6
             4'b0111: {OUT} = 14'b11100001110000; //7
             4'b1000: {OUT} = 14'b11111111111111; //8
             4'b1001: {OUT} = 14'b111101111111011; //9
             4'b1010: {OUT} = 14'b111011111110111; //a
             4'b1011: {OUT} = 14'b00111110011111; //b
             4'b1100: {OUT} = 14'b10011101001110; //c
             4'b1101: {OUT} = 14'b011110101111101; //d
             4'b1110: {OUT} = 14'b100111111001111; //e
             4'b1111: {OUT} = 14'b10001111000111; //f
        endcase
```

```
always@(SW2) //this controls which 7SD lights up

case({SW2})

3'b000: {D} = 8'b00000001; //0

3'b001: {D} = 8'b00000010; //1

3'b010: {D} = 8'b00001000; //2

3'b011: {D} = 8'b000010000; //3

3'b100: {D} = 8'b000100000; //4

3'b101: {D} = 8'b001000000; //5

3'b110: {D} = 8'b010000000; //6

3'b111: {D} = 8'b100000000; //7

endcase

endmodule
```

SW and SW2 are the inputs. OUT and D are the outputs.

## FPGA board results



The inputs are done with switches. The switches represent binary numbers. A switch pulled up represents a 1 and a switch pulled down represents a 0. In this picture, the display chosen is the display 6, and the number being displayed is the number 6.



Number 2 on display 3.



Number 10 on display 0.